<template>
  <section>
    <!--工具条-->
    <el-col :span="24" class="toolbar" style="padding-bottom: 0px;">
      <el-form :inline="true">
        <el-form-item>
          <!--v-model="表达式"：数据双向绑定-->
          <el-input v-model="keyword" placeholder="请输入文章名称或标签或类型或类型名称" style="width: 300px"></el-input>
        </el-form-item>
        <el-form-item>
          <el-button type="warning" v-on:click="keywordQuery" v-permission="'article:page'">查询</el-button>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" @click="handleAdd"  v-permission="'article:addOrUpdate'">新增</el-button>
        </el-form-item>
      </el-form>
    </el-col>

    <!--列表v-loading="listLoading"-->
    <el-table :data="tableDatas" v-loading="listLoading" @selection-change="handleSelectionChange" highlight-current-row
              style="width: 100%;">
      <!--多选框-->
      <el-table-column type="selection" width="55">
      </el-table-column>
      <el-table-column type="index" width="70" label="序号">
      </el-table-column>
      <!--   prop	对应列内容的字段名，也可以使用 property 属性  label	：显示的标题 -->
      <el-table-column prop="articlePic" width="80" label="文章封面">
        <template scope="scope"> <!--template:自定义模版--> <!--  scope="scope":获取子组件的数据-->
          <img :src="scope.row.articlePic" height="50px"/>
        </template>
      </el-table-column>
      <el-table-column prop="articleName" width="200" label="文章名称" show-overflow-tooltip> <!--show-overflow-tooltip：超出内容隐藏-->
      </el-table-column>
      <el-table-column prop="articleTag" width="150" label="文章标签" show-overflow-tooltip>
      </el-table-column>
      <el-table-column prop="articleType" width="100" label="文章类型" show-overflow-tooltip>
      </el-table-column>
      <el-table-column prop="articleTypeName" width="150" label="文章类型名称" show-overflow-tooltip>
      </el-table-column>
      <el-table-column label="文章状态" width="80">
        <template scope="scope">
          <span v-if="!scope.row.articleState" style="color:#000000">草稿</span> <!--如果当前行的articleState属性为0的时候-->
          <span v-else-if="scope.row.articleState === 1" style="color:#00ff00">发布</span>
          <span v-else="scope.row.articleState === 2" style="color:#ff0000">弃用</span>
        </template>
      </el-table-column>
      <el-table-column prop="topState" label="是否置顶" width="80">
        <template scope="scope">
          <span v-if="scope.row.topState === 0" style="color:#000000">不置顶</span>
          <span v-else="scope.row.topState === 1" style="color:#003cff">置顶</span>
        </template>
      </el-table-column>
      <el-table-column prop="publishId"  label="发布人ID">
      </el-table-column>
      <el-table-column prop="publishName" label="发布人名字">
      </el-table-column>
      <el-table-column prop="createTime" label="创建时间" width="100px">
      </el-table-column>
      <el-table-column prop="updateTime" label="更新时间" width="100px">
      </el-table-column>
      <el-table-column prop="articleReadCount"  label="阅读量">
      </el-table-column>
      <el-table-column prop="articleStarNum" label="点赞数">
      </el-table-column>
      <el-table-column prop="articleCommentNum" label="评论数">
      </el-table-column>

      <el-table-column
          label="文章推荐状态">
        <template slot-scope="scope">
          <div :style="{ color: scope.row.articleRecommend =='1' ? 'green' : 'red' }">
            {{ scope.row.articleRecommend== '1' ? '推荐' : '不推荐' }}
          </div>
        </template>
      </el-table-column>
      <el-table-column label="操作" width="300">
        <template scope="scope">
          <el-button size="small" @click="handleEdit(scope.row)"  v-permission="'article:addOrUpdate'">编辑</el-button>
          <el-button type="danger" size="small" @click="handleDel(scope.row)"  v-permission="'article:delete'">删除</el-button>
          <el-button @click="rowOverdue(scope.row)">{{ scope.row.articleRecommend == '1' ? '取消推荐' : '设为推荐' }}</el-button>
        </template>
      </el-table-column>
    </el-table>
    <!--工具条-->
    <el-col :span="24" class="toolbar">
      <el-button type="danger" :disabled="this.sels.length === 0" @click="handlePatchDel"  v-permission="'article:patchDel'">批量删除</el-button> <!--disabled：是否禁用状态 --- 当sels的长度等于0的时候禁用-->
      <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="currentPage"
                     :page-sizes="[5, 10, 15]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper"
                     :total="totals" style="float:right;">
      </el-pagination>
    </el-col>

    <!--添加或修改界面-->
    <el-dialog title="保存文章" :visible.sync="saveFormVisible" :close-on-click-modal="false">
      <el-form :model="saveForm" label-width="120px" :rules="saveFormRules" ref="saveForm"> <!--:rules：表单检验规则-->
        <el-form-item label="文章名称" prop="articleName"><!--prop：校验的字段-->
          <el-input v-model="saveForm.articleName" auto-complete="off"></el-input>
        </el-form-item>
        <el-form-item label="文章标签">
          <el-input v-model="saveForm.articleTag" auto-complete="off"></el-input>
        </el-form-item>
        <el-form-item label="文章封面">
            <!--
            action：必选参数，上传的地址
            limit：最大允许上传个数
            on-success：文件上传成功时的钩子	function(response, file, fileList)
            on-remove：文件列表移除文件时的钩子	function(file, fileList)
            on-exceed:文件超出个数限制时的钩子
            file-list:上传的文件列表
            list-type	文件列表的类型-->
          <el-upload
              class="upload-demo"
              action="http://localhost:8080/minio"
              :limit=1
              :on-success="handleSuccess"
              :on-remove="handleRemove"
              :on-exceed="handleExceed"
              :file-list="fileList"
              list-type="picture">
            <el-button size="small" type="primary">点击上传</el-button>
            <div slot="tip" class="el-upload__tip">只能上传jpg/png文件，且不超过500kb</div>
          </el-upload>
        </el-form-item>
        <el-form-item label="文章类型">
          <!--
               clearable	是否支持清空选项
               options	可选项数据源，键名可通过 Props 属性配置
               props	配置选项
                  value	指定选项的值为选项对象的某个属性值
                  label	指定选项标签为选项对象的某个属性值
                  children	指定选项的子选项为选项对象的某个属性值
                  checkStrictly	是否严格的遵守父子节点不互相关联-----可以直选中父节点而不选中子节点
                  emitPath	在选中节点改变时，是否返回由该节点所在的各级菜单的值所组成的数组，若设置 false，则只返回该节点的值
            -->
          <el-cascader
              v-model="saveForm.articleType"
              clearable
              :options="options"
              :props="{
                 label:'typeName',
                 value:'id',
                 checkStrictly:true,
                 emitPath:false
             }"
          ></el-cascader>
        </el-form-item>
        <el-form-item label="文章状态">
          <el-radio-group v-model="saveForm.articleState">
            <el-radio :label="0">草稿</el-radio>
            <el-radio :label="1">发布</el-radio>
            <el-radio :label="2">弃用</el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item label="置顶状态">
          <el-radio-group v-model="saveForm.topState">
            <el-radio :label="0">不置顶</el-radio>
            <el-radio :label="1">置顶</el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item label="文章推荐状态">
          <el-radio-group v-model="saveForm.articleRecommend">
            <el-radio :label="0">不推荐</el-radio>
            <el-radio :label="1">推荐</el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item label="文章社区">

        </el-form-item>
        <el-form-item label="文章备注">
          <el-input type="textarea" v-model="saveForm.articleRemark" auto-complete="off"></el-input> <!--textarea：文本域-->
        </el-form-item>
        <el-form-item label="文章内容" prop="articleContent">
          <div class="edit_container">
            <quill-editor v-model="saveForm.articleContent"
                          :options="editorOption"> <!--富文本编辑器-->
            </quill-editor>
          </div>
        </el-form-item>
      </el-form>

      <div slot="footer" class="dialog-footer">
        <el-button @click.native="saveFormVisible = false">取消</el-button>
        <el-button type="primary" @click.native="saveSubmit">提交</el-button>
      </div>
    </el-dialog>
  </section>
</template>

<script>
//引入Vue的ueditor的资源
import {quillEditor} from "vue-quill-editor"; //调用编辑器
import 'quill/dist/quill.core.css';
import 'quill/dist/quill.snow.css';
import 'quill/dist/quill.bubble.css';
// 工具栏配置
const toolbarOptions = [
  ["bold", "italic", "underline", "strike"], // 加粗 斜体 下划线 删除线 -----['bold', 'italic', 'underline', 'strike']
  ["blockquote", "code-block"], // 引用  代码块-----['blockquote', 'code-block']
  [{header: 1}, {header: 2}], // 1、2 级标题-----[{ header: 1 }, { header: 2 }]
  [{list: "ordered"}, {list: "bullet"}], // 有序、无序列表-----[{ list: 'ordered' }, { list: 'bullet' }]
  [{script: "sub"}, {script: "super"}], // 上标/下标-----[{ script: 'sub' }, { script: 'super' }]
  [{indent: "-1"}, {indent: "+1"}], // 缩进-----[{ indent: '-1' }, { indent: '+1' }]
  [{direction: "rtl"}], // 文本方向-----[{'direction': 'rtl'}]
  [{size: ["small", false, "large", "huge"]}], // 字体大小-----[{ size: ['small', false, 'large', 'huge'] }]
  [{header: [1, 2, 3, 4, 5, 6, false]}], // 标题-----[{ header: [1, 2, 3, 4, 5, 6, false] }]
  [{color: []}, {background: []}], // 字体颜色、字体背景颜色-----[{ color: [] }, { background: [] }]
  [{font: []}], // 字体种类-----[{ font: [] }]
  [{align: []}], // 对齐方式-----[{ align: [] }]
  ["clean"], // 清除文本格式-----['clean']
  ["image", "link"] // 链接、图片、视频-----['link', 'image', 'video']
];

export default {
  // 富文本编辑器
  components: {
    quillEditor
  },
  data() {
    return {
      //1.分页查询相关数据
      totals: 0,//总记录条数
      currentPage: 1,//当前页,要传递到后台的
      pageSize: 5, //每页显示多少条
      tableDatas: [], //当前页数据
      listLoading: false,

      //2.高级查询相关数据
      keyword: '',

      //3.删除相关数据

      //4.批量删除相关数据
      sels: [], //存储多选记录

      //5.添加和修改相关数据
      saveFormVisible: false,
      saveForm: {
        id: null,
        articleName: '',
        articlePic: null,
        articleTag: '',
        articleType: null,
        articleState: 1,
        topState: 0,
        articleRemark: 0,
        articleContent: '',
        parentId: null,


      },

      //6.添加和修改校验规则-表单项校验
      saveFormRules: {
        articleName: [ // 校验的字段
            /*required	是否必填，如不设置，则会根据校验规则自动生成（不会进行校验也能添加成功） */
          {required: true, message: '请输入文章名称'},
        ],
        articleContent: [
          {required: true, message: '请输入文章内容', trigger: 'blur'},
        ],

      },

      // 7.类型树
      options: [],


      //8.富文本编辑器配置
      editorOption: {
        modules: {
          //工具栏定义的
          toolbar: toolbarOptions
        },
        //主题
        theme: "snow",
        placeholder: "请开始书写您的博客内容..."
      },

      // 图片上传
      fileList: [],
      // 图片上传和删除的地址
      url:"http://101.35.235.40:9090/java0403/",

      articleRecommend:null,
    }



  },
  methods: {
    //1.分页查询相关方法
    //1.1.获取列表数据
    getTableData() {
      // post请求的参数  params:参数
      var params = {
        currentPage: this.currentPage,
        pageSize: this.pageSize,
        keyword: this.keyword
      }
      this.$http.post("/article", params).then(res => {
        // console.log(res);

        this.tableDatas = res.data.list;
        this.totals = res.data.total;
      })
    },
    //1.2.选择第几页时触发
    handleCurrentChange(currentPage) {
      // 设置现在的页数为选中的页数
      this.currentPage = currentPage;
      // 调用分页查询的方法（里面的页数参数已经变为更改后的页数参数）
      this.getTableData();
    },
    //1.3.选择每页显示记录条数时触发
    handleSizeChange(pageSize) {
      // 设置每页显示的条数为选中的条数
      this.pageSize = pageSize;
      // 调用分页查询的方法（里面的每页显示条数参数已经变为更改后的每页显示条数参数）
      this.getTableData();
    },

    //2.高级查询相关方法
    keywordQuery() {
      // 设置当前为1，防止在其他页的时候查询数据导致查询出来的数据没有那么多页然后不显示
      this.currentPage = 1;
      this.getTableData();
    },

    //3.删除相关方法
    handleDel(row) {
      // $confirm：弹框
      this.$confirm('你确定要删除当前数据吗?', '温馨提示', {
        type: 'warning'
      }).then(() => {  // 点击确认后发生的事情
        this.$http.delete("/article/" + row.id).then(res => { // 发送delete请求
          // 发送请求成功后执行的代码
          if (res.data.success) {
            // 删除成功后从minio里面删除图片
            if (row.articlePic != null && row.articlePic != ''){ // 判断照片是否为空，不为空就执行以下方法
              // Article.vue:297 http://60.204.187.34:9090/java0403/1720161681973.gif
              // console.log(row.articlePic)
             var name =  row.articlePic.substring( row.articlePic.lastIndexOf("/") + 1); // 截取图片的名字
              this.$http.delete("minio/" + name).then(res => { // 执行在minio里面删除图片的方法
                if (res.data.success){
                  this.$message.success("文件删除成功")
                }else {
                  this.$message.error("文件删除失败")
                }
              })
            }
            this.getTableData() // 删除成功后重新刷新页面
          } else {
            this.$message.error("网络繁忙，请稍后再试 - 500") // 删除失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
          }
        }).catch(() => {
          // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
          this.$message.error("网络繁忙，请稍后再试 - 404/400")
        })
      }).catch(() => { // 点击取消后发生额事情
      });
    },


    //4.批量删除相关方法
    //4.1.选项改变时触发
    handleSelectionChange(val) {
      this.sels = val;
    },
    //4.2.批量删除
    handlePatchDel() {
      /*map() 方法是数组原型的一个函数，该函数用于对数组中的每个元素进行处理，将其转换为另一个值，最终返回一个新的数组，该数组包含了经过处理后的每个元素。*/
      /*将sels数组里面的user对象转为user对象的id属性组成的数组*/
      /*user => user.id：箭头函数*/
      var ids = this.sels.map(user => user.id)
      var articlePics = this.sels.map(user => user.articlePic)
      // 0:"http://60.204.187.34:9090/java0403/1720164497820.jpg"
      //1:""
      //2:"http://60.204.187.34:9090/java0403/1720164516837.png"
      //3:"http://60.204.187.34:9090/java0403/1720164566842.jpg"
      //4:"http://60.204.187.34:9090/java0403/1720164574970.jpg"
      // console.log(articlePics)
      this.$confirm('你确定要删选中的数据吗?', '温馨提示', {
        type: 'warning',
      }).then(() => {  // 点击确认后发生的事情
        this.$http.patch("/article", ids).then(res => { // 发送delete请求
          // 发送请求成功后执行的代码
          if (res.data.success) {
            for (let articlePic of articlePics) { // 循环图片对象
              if (articlePic != null && articlePic != '') { // 如果图片字段不为空字符串或''
                var name = articlePic.substring(articlePic.lastIndexOf("/") + 1); // 截取名字
                this.$http.delete("minio/" + name).then(res => { // 执行在minio里面删除图片的方法
                  if (res.data.success){
                    this.$message.success("文件删除成功")
                  }else {
                    this.$message.error("文件删除失败")
                  }
                })
              }
            }
            this.getTableData() // 删除成功后重新刷新页面
          } else {
            this.$message.error("网络繁忙，请稍后再试 - 500") // 删除失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
          }
        }).catch(res => {
          // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
          this.$message.error("网络繁忙，请稍后再试 - 404/400")
        })
      }).catch(() => { // 点击取消后发生额事情
      });

    },

    //5.添加和修改相关方法
    //5.1.点击添加弹出对话框
    handleAdd() {
      this.saveForm = {
        id: null,
        articleName: '',
        articlePic: '',
        articleTag: '',
        articleType: null, // 字符串默认为''，其他类型默认为null
        articleState: 1, // 设置默认值
        topState: 0,
        articleRemark: '',
        articleContent: '',
        parentId: null,
        articleRecommend:0,

      }

      //  维护fileList——维护上传的图片在添加的表单里保持为空的状态
      this.fileList = [];

      // 调用类型树
      this.typeTree();


      // 显示表单
      this.saveFormVisible = true;
    },

    //5.2.点击修改弹出对话框
    handleEdit(row) {
      /*Object.assign() 方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象。*/
      /*Object.assign(target, ...sources) 【target：目标对象】，【souce：源对象（可多个）】*/
      /*设置回显，并且更改表单里面的内容外面数据不受影响*/
      this.saveForm = Object.assign({}, row),

      this.articleRecommend = row.articleRecommend;

      this.typeTree();

      // 修改的时候显示图片的内容
      this.fileList=[]; // 维护fileList —— 清空fileList里面的数据（防止上一次上传图片导致fileList里面有内容未清空）
     if (this.saveForm.articlePic){ // 判断当前对象是否有照片
       var name = row.articlePic.substring(row.articlePic.lastIndexOf("/") + 1) // 截取照片的后缀 http://60.204.187.34:9090/java0403/1720090255364.jpg
       this.fileList.push({url:row.articlePic,name:name}) // 将照片添加进fileList里，可以将照片在修改表单的页面里显示
     }


      // 显示表单
      this.saveFormVisible = true;
    },

    //5.3.提交表单数据操作数据库
    saveSubmit() {
      /*this.$refs是Vue实例提供的属性，允许你访问组件中的DOM元素或子组件。这使得你能够在需要的时候直接操作DOM或与子组件进行通信，而不需要通过props或事件的方式进行交互。*/
      //  validate	对整个表单进行校验的方法，参数为一个回调函数。该回调函数会在校验结束后被调用，并传入两个参数：是否校验成功和未通过校验的字段。若不传入回调函数，则会返回一个 promise
      /*this.$refs.saveForm.validate：校验提交的表单*/
      this.$refs.saveForm.validate((valid) => {
        if (valid) {
          if(this.saveForm.articleRecommend == 0){
            this.$http.put("/article", this.saveForm).then(res => {
              // 发送请求成功后执行的代码
              if (res.data.success) {
                this.getTableData()
              } else {
                this.$message.error("网络繁忙，请稍后再试 - 500") // 失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
              }
            }).catch(res => {
              // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
              this.$message.error("网络繁忙，请稍后再试 - 404/400")
            })
          }else{
            this.$http.get("/article/getArticleRecommendCount").then(res => {
              // 发送请求成功后执行的代码
              if (res.data.success) {
                var count =  res.data.data;
                if (count >= 10  && (this.articleRecommend == 0 || this.saveForm.id == null)){
                  this.$message.error("推荐数超过10个，请删除一个推荐")
                  this.saveForm.articleRecommend = 0
                }else {
                  this.$http.put("/article", this.saveForm).then(res => {
                    // 发送请求成功后执行的代码
                    if (res.data.success) {
                      this.getTableData()
                    } else {
                      this.$message.error("网络繁忙，请稍后再试 - 500") // 失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
                    }
                  }).catch(res => {
                    // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
                    this.$message.error("网络繁忙，请稍后再试 - 404/400")
                  })
                }
              } else {
                this.$message.error("网络繁忙，请稍后再试 - 500") // 失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
              }
            }).catch(res => {
              // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
              this.$message.error("网络繁忙，请稍后再试 - 404/400")
            })
          }
          this.saveFormVisible = false;
        } else {
          this.$message.error("表单验证失败")
        }

      })

    },

    // 6.查询类型树
    typeTree() {
      this.$http.get("/articleType/typeTree").then(res => {
        this.options = res.data;
      })
    },



    // 7.图片上传
    // 7.1文件上传成功后的钩子
    handleSuccess(response, file, fileList) {
      // 维护articlePic——设置图片的属性，方便访问
      this.saveForm.articlePic =this.url + response.data;

      // 维护fileList——因为是异步，防止添加的时候里面有一张图片了，所以需要清空
      this.fileList=[];
      // 为了前端页面能够显示
      this.fileList.push({
        name:response.data,
        url:this.saveForm.articlePic
      })


    },
    // 7.2移除文件的钩子
    handleRemove(file, fileList) {
      // console.log(file)
     // let name = file.response.data;
      let name = file.url.substring(file.url.lastIndexOf("/") + 1)
      this.$http.delete("minio/" + name).then(res => {
        if (res.data.success){
          this.$message.success("文件删除成功")
        }else {
          this.$message.error("文件删除失败")
        }
      })

      // 清除fileList——因为添加图片的时候图片会保存在fileList中，当进行下一次操作的时候fileList中还有图片，还会显示出来
      this.fileList=[];
      // 删除图片的时候同时清除数据库里面的图片内容
      this.saveForm.articlePic = '';

    },
    // 7.3超出个数限制的方法
    handleExceed(files, fileList) {
      this.$message.error("最多只能上传一张图片")
    },

    rowOverdue(row) {
     if(row.articleRecommend == 1){
       row.articleRecommend = 0
       this.$http.put("/article", row).then(res => {
         // 发送请求成功后执行的代码
         if (res.data.success) {
           this.getTableData()
         } else {
           this.$message.error("网络繁忙，请稍后再试 - 500") // 失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
         }
       }).catch(res => {
         // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
         this.$message.error("网络繁忙，请稍后再试 - 404/400")
       })
     }else{
       this.$http.get("/article/getArticleRecommendCount", row).then(res => {
         // 发送请求成功后执行的代码
         if (res.data.success) {
           var count =  res.data.data;
           if (count >= 10){
             this.$message.error("推荐数超过10个，请删除一个推荐")
             row.articleRecommend = 0
           }else {
             row.articleRecommend = 1
             this.$http.put("/article", row).then(res => {
               // 发送请求成功后执行的代码
               if (res.data.success) {
                 this.getTableData()
               } else {
                 this.$message.error("网络繁忙，请稍后再试 - 500") // 失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
               }
             }).catch(res => {
               // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
               this.$message.error("网络繁忙，请稍后再试 - 404/400")
             })
           }
         } else {
           this.$message.error("网络繁忙，请稍后再试 - 500") // 失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
         }
       }).catch(res => {
         // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
         this.$message.error("网络繁忙，请稍后再试 - 404/400")
       })
     }

      // this.$http.put("/article", row).then(res => {
      //   // 发送请求成功后执行的代码
      //   if (res.data.success) {
      //     this.getTableData()
      //   } else {
      //     this.$message.error("网络繁忙，请稍后再试 - 500") // 失败后返回的信息  后端错误：  500 【服务器错误】 - 服务器内部错误/代码有异常
      //   }
      // }).catch(res => {
      //   // 发送失败后返回的事情（前端错误：400 【请求错误】 - 请求语法错误/参数错误   404 【请求错误】 - 请求资源未找到（url错误））
      //   this.$message.error("网络繁忙，请稍后再试 - 404/400")
      // })

    },

  },

  mounted() {
    // 页面加载完成后执行获取列表数据的方法
    this.getTableData();
  }
}

</script>

<style scoped></style>
